<template>
	<view class="homeLayout pageBg" >
		
		<custom-nav-bar title="推荐"></custom-nav-bar>
		
		<view class="banner">
			<swiper circular indicator-dots indicator-color="rgb(255,255,255,0.5)"
				indicator-active-color="#fff" autoplay
			>
			<swiper-item v-for="item in bannerList" :key="item._id">
				<image :src="item.picurl" mode="aspectFill"></image>
			</swiper-item>
			</swiper>
		</view>
			
			<view class="notice">
				<view class="left">
					<uni-icons type="sound-filled" size="20"></uni-icons>
					<text class="text">公告</text>
				</view>
				<view class="center">
						<swiper vertical autoplay interval="1500" duration="300" circular>
							<swiper-item v-for="item in notice" :key="item._id" >
								
								
								<navigator :url="'/pages/notice/detail?id='+item._id">
									{{item.title}}
									</navigator>
							</swiper-item>
						
						</swiper>
				</view>
				<view class="right">
					<uni-icons type="right" size="16" ></uni-icons>
				</view>
			</view>
			<view class="select">
				<common-title>
					<template #name>
						每日推荐
					</template>
					<template #custom>
						<view class="date">
							<uni-icons type="calendar" size="18" ></uni-icons>
							<view class="text">
								<uni-dateformat :date="Date.now()" format="dd"></uni-dateformat>
								日
							</view>
							
						</view>
					</template>
				</common-title>
				<view class="content">
					<scroll-view scroll-x>
						<view class="box" v-for="item in dayRandom" :key="item._id" @click="goPreprw">
							<image :src="item.smallPicurl" mode="aspectFill"></image>
						</view>
					</scroll-view>
				</view>
			</view>
			
			<view class="theme">
				<common-title>
					<template #name>
						专题精选
					</template>
					
					<template #custom>
						<navigator url="" class="more">More+</navigator>
					
					</template>
				</common-title>
				
				<view class="content">
					<theme-item v-for="item in classify" :key="item._id"
					:item="item"
					></theme-item>
					<theme-item :isMore="true"></theme-item>
				</view>
				
			</view>
	</view>
</template>

<script setup>
import { ref } from 'vue';
import {apiGetBanner,apiDayRandom,apiNotice,apiGetclassify} from '@/api/api.js'
import {onShareAppMessage,onShareTimeline} from '@dcloudio/uni-app'
	const bannerList = ref([])
	const dayRandom =ref([])
	const notice =ref([])
	const classify = ref([])
	
	const getBanner = async ()=>{
		let res = await apiGetBanner();
			bannerList.value= res.data
	}
	
	const getDayRandom = async()=>{
		let res = await apiDayRandom();
			dayRandom.value= res.data
		
	}
	
	const getnotice = async()=>{
		let res = await apiNotice({
			select:true
		});
			notice.value= res.data
	}
	
	const getClassify = async ()=>{
		let res = await apiGetclassify({
			select:true
		});
		classify.value = res.data;
		// console.log(res);
	}
	
	
	getBanner();
	getDayRandom();
	getnotice();
	getClassify();
	
	const goPreprw = ()=>{
		uni.navigateTo({
			url:'/pages/preview/preview'
		})
	}
	
	// const goDetail =()=>{
	// 	uni.navigateTo({
	// 		url:'/pages/notice/detail?id='+item._id
	// 	})
	// }
	
	// 分享
	onShareAppMessage((e)=>{
		return {
			title:'咸虾米壁纸',
			path:"/pages/index/index"
		}
	})
	
	onShareTimeline(()=>{
		return {
			title:"咸虾米壁纸~",
			// imageUrl:bannerList.value[0].pacurl
		}
	})
	
</script>

<style lang="scss" scoped>
.homeLayout{
	.banner{
		width: 750rpx;
		padding:30rpx 0;
		swiper{
			width: 750rpx;
			height: 340rpx;
			&-item{
				width: 100%;
				height: 100%;
				padding:0 30rpx;
				image{
					width: 100%;
					height: 100%;
					border-radius: 10rpx;
				}
			}
		}
	}
	.notice{
		width: 690rpx;
		height: 80rpx;
		line-height: 80rpx;
		background: #f9f9f9;
		margin: 0 auto;
		border-radius: 80rpx;
		display: flex;
		.left{
			width: 140rpx;
			display: flex;
			align-items: center;
			justify-content: center;
			:deep(){
				.uni-icons{
					color:$brand-theme-color !important;
				}
			}			
			.text{
				color:$brand-theme-color;
				font-weight: 600;
				font-size: 28rpx;
			}
		}
		.center{
			flex:1;
			swiper{
				height: 100%;
				&-item{
					height: 100%;
					font-size: 30rpx;
					color:#666;
					overflow: hidden;
					white-space: nowrap;
					text-overflow: ellipsis;
				}
			}
		}
		.right{
			width: 70rpx;
			display: flex;
			align-items: center;
			justify-content: center;
		}
	}
	
	.select{
		padding-top:50rpx;
		.date{
			color:$brand-theme-color;
			display: flex;
			align-items: center;
			:deep(){
				.uni-icons{
					color:$brand-theme-color !important;
				}
			}	
			.text{
				margin-left:5rpx;
			}
		}
		.content{
			width: 720rpx;
			margin-left: 30rpx;
			margin-top: 30rpx;
			scroll-view{
				white-space: nowrap;
				.box{
					width: 200rpx;
					height: 430rpx;
					display: inline-block;
					margin-right: 15rpx;
					image{
						width: 100%;
						height: 100%;
						border-radius: 10rpx;
					}
				}
				.box:last-child{margin-right: 30rpx;}
			}
		}
	}
	
	.theme{
		padding:50rpx 0;
		.more{
			font-size: 32rpx;
			color:#888;
			
		}
		.content{
			margin-top:30rpx;
			padding:0 30rpx;
			display: grid;
			gap:15rpx;
			grid-template-columns: repeat(3,1fr);
		}
	}
}
</style>
